<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"
      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<style>
    input#search_provideridTree_select_input_id {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input#provideridTree_select_input_id {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input#leaderprovideridTree_select_input_id {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input.layui-input.layui-unselect {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input#search_goodsidTree_select_input_id {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input#goodsidTree_select_input_id {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input#leadergoodsidTree_select_input_id {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }

    input.layui-input.layui-unselect {
        border-radius: 10px;
        height: 30px;
        margin-top: 4px;
    }
</style>
<head>
    <meta charset="utf-8">
    <title>layui</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="../../../lib/layui-v2.6.3/css/layui.css" media="all">
    <link rel="stylesheet" href="../../../css/public.css" media="all">
</head>
<body>
<div class="layuimini-container">
    <div class="layuimini-main">
        <fieldset class="layui-elem-field layui-field-title" style="margin-top: 15px;">
            <legend>搜索条件</legend>
        </fieldset>
        <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form">
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">供应商名称</label>
                    <div class="layui-input-inline">
                        <select name="providerid" id="select_providerid">
                            <option value="0">请选择供应商</option>
                        </select>
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">商品名称</label>
                    <div class="layui-input-inline">
                        <select name="goodsid" id="select_goodsid">
                            <option value="0">请选择商品</option>
                        </select>
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">开始时间</label>
                    <div class="layui-input-inline">
                        <input type="text" name="startTime" id="startTime" readonly="readonly" placeholder="yyyy-MM-dd"
                               class="layui-input input-radius">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">结束时间</label>
                    <div class="layui-input-inline">
                        <input type="text" name="endTime" id="endTime" readonly="readonly" placeholder="yyyy-MM-dd"
                               class="layui-input input-radius">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-input-block" style="text-align: center;padding-right: 15%;">
                    <button type="button" class="layui-btn layui-btn-sm layui-btn-radius" lay-submit=""
                            lay-filter="doSearch"><i
                            class="layui-icon layui-icon-search layui-icon-normal"></i>查询
                    </button>
                    <button type="reset" class="layui-btn layui-btn-sm layui-btn-radius layui-btn-warm"><i
                            class="layui-icon layui-icon-refresh"></i><span>重置</span>
                    </button>
                </div>
            </div>
        </form>

        <table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter"></table>

        <!--数据表格-->
        <div>
            <table class="layui-hide" id="inportTable" lay-filter="inportTable"></table>
            <div id="inportToolBar" style="display: none">
                <button type="button" lay-event="add" shiro:hasPermission="inport:create"
                        class="layui-btn layui-btn-sm layui-btn-normal layui-btn-radius">
                    <i class="layui-icon layui-icon-add-1"></i>添加进货
                </button>
            </div>
            <div id="inportRowBar" style="display: none;">
                <button type="button" lay-event="update" shiro:hasPermission="inport:update"
                        class="layui-btn layui-btn-sm layui-btn-radius"><i
                        class="layui-icon layui-icon-edit"></i>编辑
                </button>
                <button type="button" lay-event="delete" shiro:hasPermission="inport:delete"
                        class="layui-btn layui-btn-sm layui-btn-danger layui-btn-radius"><i
                        class="layui-icon layui-icon-delete"></i>删除
                </button>
                <button type="button" lay-event="back" shiro:hasPermission="inport:back"
                        class="layui-btn layui-btn-sm layui-btn-warm layui-btn-radius"><i
                        class="layui-icon layui-icon-delete"></i>退货
                </button>
            </div>
        </div>

    </div>
    <!--添加和修改弹出层-->
    <div id="addOrUpdateDiv" style="display: none;padding: 10px;padding-right: 5%">
        <form action="" method="post" class="layui-form" id="dataFrm" lay-filter="dataFrm">
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">供应商名称</label>
                    <div class="layui-input-inline">
                        <select name="providerid" id="providerid" lay-filter="providerid">
                            <option value="0">请选择供应商</option>
                        </select>
                        <div class="mydiv" title="不可修改"
                             style="position:absolute;width:100%;height:100%;left:0px;top:0px;background:#fff;opacity:0;filter:alpha(opacity=0)"></div>
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">商品名称</label>
                    <div class="layui-input-inline">
                        <select name="goodsid" id="goodsid">
                            <option value="0">请选择商品</option>
                        </select>
                    </div>
                    <div class="mydiv" title="不可修改"
                         style="position:absolute;width:100%;height:100%;left:0px;top:0px;background:#fff;opacity:0;filter:alpha(opacity=0)"></div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">进货数量</label>
                    <div class="layui-input-block">
                        <input type="hidden" name="id">
                        <input type="text" name="number" lay-verify="required|number" autocomplete="off"
                               class="layui-input input-radius" placeholder="请输入进货数量">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">进货价格</label>
                    <div class="layui-input-block">
                        <input type="text" name="inportprice" lay-verify="required|number" autocomplete="off"
                               class="layui-input input-radius" placeholder="请输入进货价格">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">支付类型</label>
                    <div class="layui-input-block">
                        <input type="radio" name="paytype" value="微信" title="微信">
                        <input type="radio" name="paytype" value="支付宝" title="支付宝" checked>
                        <input type="radio" name="paytype" value="银联" title="银联">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">进货备注</label>
                    <div class="layui-input-block">
                        <textarea name="remark" placeholder="请输入进货备注" class="layui-textarea" cols="200"
                                  rows="8"></textarea>
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-input-block" style="text-align: center;padding-right: 7%">
                    <button type="button" class="layui-btn layui-btn-radius" lay-submit="" lay-filter="doSubmit"
                            id="doSubmit"><i
                            class="layui-icon layui-icon-search layui-icon-normal"></i>提交
                    </button>
                    <button type="reset" class="layui-btn layui-btn-radius layui-btn-warm"><i
                            class="layui-icon layui-icon-refresh"></i><span>重置</span>
                    </button>
                </div>
            </div>
        </form>
    </div>
    <!--退货弹出层-->
    <div id="backGoodsDiv" style="display: none;padding-right: 3%">
        <form action="" method="post" class="layui-form" id="dataFrmBack" lay-filter="dataFrmBack">

            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">退货数量</label>
                    <div class="layui-input-block">
                        <input type="hidden" name="id">  <!-- 进货单ID  -->
                        <input type="hidden" name="currentNumber" id="currentNumber">  <!-- 进货单中进货数量  -->
                        <input type="text" name="number" lay-verify="required|checkNumber" autocomplete="off"
                               class="layui-input input-radius" placeholder="请输入退货数量">
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">退货备注</label>
                    <div class="layui-input-block">
                        <textarea name="remark" placeholder="请输入退货备注" class="layui-textarea" cols="200"
                                  rows="8"></textarea>
                    </div>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-input-block" style="text-align: center;padding-right: 7%">
                    <button type="button" class="layui-btn layui-btn-radius" lay-submit="" lay-filter="doBackSubmit"
                            id="doBackSubmit"><i
                            class="layui-icon layui-icon-search layui-icon-normal"></i>提交
                    </button>
                    <button type="reset" class="layui-btn layui-btn-radius layui-btn-warm"><i
                            class="layui-icon layui-icon-refresh"></i><span>重置</span>
                    </button>
                </div>
            </div>
        </form>
    </div>
</div>

<script src="../../../lib/layui-v2.6.3/layui.js" charset="utf-8"></script>
<script type="text/javascript">

    //提升数据表格的作用域，因为底下还有一个reloadTable方法
    var tableIns;

    layui.use(['jquery', 'form', 'layer', 'table', 'laydate'], function () {
        var $ = layui.jquery;
        var form = layui.form;
        var layer = layui.layer;
        var table = layui.table;
        var laydate = layui.laydate;


        var start = laydate.render({
            elem: '#startTime', //指定元素
            format:'yyyy-MM-dd',
            type:"dateTime",
            done:function (value,date) {
                // 结束时间大于开始时间
                end.config.min ={
                    year:date.year,
                    month:date.month-1, //关键
                    date: date.date,
                    hours: 0,
                    minutes: 0,
                    seconds : 0
                };
            }
        });
        var end = laydate.render({
            elem: '#endTime', //指定元素
            type:"dateTime",
            format:'yyyy-MM-dd',
            done:function (value,date) {
                // 开始时间小于结束时间
                start.config.max={
                    year:date.year,
                    month:date.month-1,//关键
                    date: date.date,
                    hours: 0,
                    minutes: 0,
                    seconds : 0
                }
            }
        });



        //初始化表格 加载数据
        tableIns = table.render({
            elem: "#inportTable",
            title: "进货数据表格",
            url: "/inport/loadAllInport",
            toolbar: "#inportToolBar",
            page: true,
            height: "full-180",
            cols: [[
                {field: 'id', title: 'ID', align: 'center', width: '50'},
                {field: 'providername', title: '供应商', align: 'center', width: '100'},
                {field: 'goodsname', title: '商品名称', align: 'center', width: '150'},
                {field: 'paytype', title: '支付类型', align: 'center', width: '90'},
                {field: 'inporttime', title: '进货时间', align: 'center', width: '170'},
                {field: 'operateperson', title: '操作员', align: 'center', width: '130'},
                {field: 'number', title: '进货数量', align: 'center', width: '100'},
                {field: 'size', title: '商品规格', align: 'center', width: '100'},
                {field: 'inportprice', title: '进货价格', align: 'center', width: '120'},
                {field: 'remark', title: '备注', align: 'center', width: '120'},
                {fixed: 'right', title: '操作', toolbar: '#inportRowBar', align: 'center', width: '260'}
            ]],
            done: function (data, curr, count) {
                //不是第一页时，如果当前返回的数据为0那么就返回上一页
                if (data.data.length == 0 && curr != 1) {
                    tableIns.reload({
                        page: {
                            curr: curr - 1
                        }
                    })
                }
            }
        });

        //监控模糊查询按钮事件
        form.on("submit(doSearch)", function (data) {
            tableIns.reload({
                where: data.field,
                page: {
                    curr: 1
                }
            });
            return false;
        });

        //监控工具条事件
        table.on("toolbar(inportTable)", function (obj) {
            switch (obj.event) {
                case 'add':
                    openAddLayer();
                    break;
                case 'deleteBatch':
                    batchDeleteInport();
                    break;
            }
            ;
        });

        //监控行工具条事件
        table.on("tool(inportTable)", function (obj) {
            //获取当前行数据
            var data = obj.data;
            switch (obj.event) {
                case 'delete':
                    deleteInport(data);
                    break;
                case 'update':
                    updateInport(data);
                    break;
                case 'back':
                    backInport(data);
                    break;
            }
            ;
        });

        //初始化供应商名称的下拉列表
        $.get("/provider/loadAllProviderForSelect", function (res) {
            var data = res.data;
            var dom = $("#select_providerid");
            var html = '<option value="0">请选择供应商</option>';
            $.each(data, function (index, item) {
                html += '<option value="' + item.id + '">' + item.providername + '</option>';
            })
            dom.html(html);
            //重新渲染下拉列表
            form.render("select");
        });
        //初始化商品名称的下拉列表
        $.get("/goods/loadAllGoodsForSelect", function (res) {
            var data = res.data;
            var dom = $("#select_goodsid");
            var html = '<option value="0">请选择商品</option>';
            $.each(data, function (index, item) {
                html += '<option value="' + item.id + '">' + item.goodsname + '-[' + item.size + ']-' + '[' + item.providername + ']' + '</option>';
            });
            dom.html(html);
            //重新渲染下拉列表
            form.render("select");
        });

        var mainIndex;
        var url;

        //打开添加弹出层
        function openAddLayer() {
            mainIndex = layer.open({
                type: 1,
                content: $("#addOrUpdateDiv"),
                area: ['700px', '500px'],
                title: '添加进货',
                success: function () {
                    $("#dataFrm")[0].reset();
                    //初始化供应商的下拉列表
                    initProviderSelect();
                    //使该div隐藏
                    $(".mydiv").hide();
                    url = "/inport/addInport";

                }
            });
        }

        //打开修改的弹出层
        function updateInport(data) {
            mainIndex = layer.open({
                type: 1,
                content: $("#addOrUpdateDiv"),
                area: ['700px', '500px'],
                title: '修改商品进货',
                success: function () {
                    //清空原有的数据
                    $("#dataFrm")[0].reset();
                    //装载新的数据
                    form.val("dataFrm", data);
                    //供应商进行反选
                    initProviderSelect(data.providerid);
                    //商品进行反选
                    initGoodsSelect(data.providerid, data.goodsid);
                    //禁用供应商和商品的下拉列表
                    $(".mydiv").show();
                    url = "/inport/updateInport";
                }
            });
        }

        //初始化添加和修改页面的下拉列表
        function initProviderSelect(providerid) {
            //重置商品的下拉列表
            var dom = $("#goodsid");
            dom.html("");
            $.get("/provider/loadAllProviderForSelect", function (res) {
                var data = res.data;
                var dom = $("#providerid");
                var html = '<option value="0">请选择供应商</option>';
                $.each(data, function (index, item) {
                    html += '<option value="' + item.id + '">' + item.providername + '</option>';
                });
                dom.html(html);
                //如果providerid有值就进行反选
                if (providerid != undefined) {
                    dom.val(providerid);
                }
                //重新渲染下拉列表
                form.render("select");
            });
        };

        //监听供应商的下拉列表的事件
        form.on('select(providerid)', function (data) {
            var providerid = data.value;
            initGoodsSelect(providerid);
        });

        //加载商品的下拉列表
        function initGoodsSelect(providerid, goodsid) {
            $.get("/goods/loadGoodsByProviderId", {providerid: providerid}, function (res) {
                var data = res.data;
                var dom = $("#goodsid");
                var html = '<option value="0">请选择商品</option>';
                $.each(data, function (index, item) {
                    html += '<option value="' + item.id + '">' + item.goodsname + '-[' + item.size + ']-' + '[' + item.providername + ']' + '</option>';
                });
                dom.html(html);
                //如果goodsid有值就进行反选
                if (goodsid != undefined) {
                    dom.val(goodsid);
                }
                //重新渲染下拉列表
                form.render("select");
            });
        }


        form.on("submit(doSubmit)", function (data) {
            $.post(url, data.field, function (res) {

                if (res.code == 200) {
                    tableIns.reload();
                    layer.close(mainIndex);
                }
                layer.msg(res.msg);

            });
            return false;
        });


        //删除
        function deleteInport(data) {
            layer.confirm('你确定要删除这条进货信息吗？', {icon: 3, title: '提示'}, function (index) {
                $.post("/inport/deleteInport", {id: data.id}, function (res) {
                    if (res.code == 200) {
                        tableIns.reload({
                            where: "",
                        });
                    }
                    layer.msg(res.msg);
                });
                layer.close(index);
            });
        }

        //打开退货的弹出层
        function backInport(data) {
            mainIndex = layer.open({
                type: 1,
                content: $("#backGoodsDiv"),
                area: ['600px', '400px'],
                title: '商品退货',
                success: function () {
                    //清空原有的数据
                    $("#dataFrmBack")[0].reset();
                    //装载新的数据   获得进货的ID以及当前进货单的进货数量
                    form.val("dataFrmBack", {id: data.id, currentNumber: data.number});
                }
            });
        }

        //自定义验证规则
        form.verify({
            checkNumber: function (value) {
                var currentNumber = $("#currentNumber").val();
                //value为退货的数量    currentNumber为当前进货单的数量
                if (parseInt(value) > currentNumber || parseInt(value) < 1) {
                    return '退货数量只能在【0】-【' + currentNumber + '】之间';
                }
            }
        });

        //退货提交
        form.on("submit(doBackSubmit)", function (data) {
            $.post("/outport/addOutport",data.field, function (res) {
                if (res.code == 200) {
                    layer.msg(res.msg);
                    //重新加载表格数据
                    tableIns.reload();
                    //关闭退货弹出层
                    layer.close(mainIndex);
                }else if (res.code == 80004) {
                    layer.confirm('已达预警值，确认继续？', {icon: 3, title: '提示'}, function (index) {
                        $.post("/outport/addOutports",data.field,function (res) {
                            if (res.code == 200) {
                                layer.msg(res.msg);
                                //重新加载表格数据
                                tableIns.reload();
                                layer.close(index);
                                //关闭退货弹出层
                                layer.close(mainIndex);
                            }
                            layer.msg(res.msg);
                        });
                    });
                }else {
                    layer.msg(res.msg);
                }
            });
            return false;
        })



    });


</script>

</body>
</html>